草庐IT

java - Junit 测试后的数据库清理

全部标签

ruby-on-rails - Ruby on Rails 和 Twitter OAuth 的测试策略

我正在开发一个利用twitteroauth的应用程序,但在试图弄清楚如何测试twitteroauth时遇到了障碍。特别是尝试使用Cucumber和Webrat/Selenium来测试功能——注册/登录过程中的某些步骤在用户是否授予对应用程序的oauth访问权限等方面表现不同。有没有人在他们的RubyonRailsCucumber功能(或与此相关的任何其他测试框架)中成功模拟或stub部分或全部TwitterOAuth系统?任何帮助将不胜感激。 最佳答案 OP已经一年多了,但我最近发现这篇关于使用TwitterAuth和Cucumbe

ruby-on-rails - Rails 控制台数据库模式检查

我是rails/ruby的新手,我想知道如何在rails控制台中仔细检查我的数据库模式是否正确构建在railsc中ActiveRecord::Base.connection.tables给了我的输出["schema_migrations","users","expense_pictures","income_pictures","income_texts","expense_texts"]如何在控制台中检查我是否正确构建了以下架构?从用户到IncomePictures和ExpensePictures是外键。IncomePictures到ExpensePictures也是其相应文本的外键

ruby-on-rails - 模型测试中未定义局部变量或方法 'session'

我正在创建一个RubyonRails应用程序,并尝试运行涉及我的用户模型的测试,以查看“记住我”功能是否有效。我正在使用Rails的内置cookies散列来存储cookie,并使用session散列来存储当前session。我在使用session变量的地方运行了各种测试(集成、模型和Controller),但出于某种原因,在这种特殊情况下它没有被识别。NameError:undefinedlocalvariableormethod`session'for#错误发生在下面log_in_as方法的elseblock中:test_helper.rb...deflog_in_as(user,o

ruby - 如何在我的 RSpec 测试中访问 Sorcery?

巫术认证gem:https://github.com/NoamB/sorcerySorcery的创建者提供了一个示例Rails应用程序,其中包含在其Test::Unit功能测试中的Sorcery测试助手:https://github.com/NoamB/sorcery-example-app/blob/master/test/functional/users_controller_test.rb#Test::Unitfunctionaltestexamplerequire'test_helper'classUsersControllerTest@user.to_paramassert_

ruby - Rspec let() 清理

有没有办法跟踪使用let时创建的变量?我有一系列测试,其中一些使用let(:server){#blahblah}。blah的一部分是等待服务器启动,以便它在使用之前处于良好状态。当我完成该测试时,问题就来了。我想使用server.kill()终止服务器。如果我能说一些类似的内容,这将近乎完美after(:each){server.kill}但这会创建服务器并在引用时浪费所有资源/时间来创建它,如果在前面的测试中未使用该服务器,则只会立即将其终止。有没有办法跟踪并仅在服务器已被使用时清理服务器? 最佳答案 我遇到过类似的问题。解决这个

ruby - 获取/发布错误响应的 rspec 测试

我正在尝试测试httpGET错误响应消息,但似乎找不到任何信息或示例预期的错误响应是:{"success":false,"code":400,"message":"ERROR:Thisisthespecificerrormessage"}这会捕获“错误请求”,但如何验证错误响应正文中的“消息”?expect{get""}.toraise_error(/400BadRequest/)提前感谢您的任何见解! 最佳答案 此外:it'returns400status'doget'/my_bad_url'expect(response.sta

ruby - 使用 Nokogiri(而不是 Tidy)清理 HTML

tidygem不再维护并且存在多个内存泄漏问题。有些人建议使用Nokogiri。我目前正在使用以下方法清理HTML:Nokogiri::HTML::DocumentFragment.parse(html).to_html不过我有两个问题:Nokogiri删除了DOCTYPE有没有一种简单的方法可以强制清理后的HTML具有html和body标签? 最佳答案 如果您正在处理完整文档,您需要:Nokogiri::HTML(html).to_html这将强制html和body标签,并引入或保留DOCTYPE:putsNokogiri::HT

ruby-on-rails - 为什么我应该只在测试环境而不是开发或生产环境中在我的 Rails 应用程序上运行 rspec 规范?

有人告诉我,除了测试之外,我不应该在rails_env中运行我的rspec规范。在生产或开发中运行规范的潜在问题是什么?我在两者中都运行规范。我通常在开发中运行规范,除非我正在测试使用Assets管道的东西。我为此切换到生产环境并花费15分钟预编译Assets。与我当前的方法相比,使用测试环境有什么优势吗?我搜索了答案,但没有任何内容解释为什么我不应该使用dev或prod。 最佳答案 在test环境中运行测试套件(例如rspec)旨在隔离资源以解决安全问题,尤其是数据库的完整性。测试通常会损坏或完全删除数据库中的数据。这同样适用于所

ruby - RSpec:使用线程进行测试

在RSpec中,我有创建新线程的函数,并在该线程内执行一些操作——在我的例子中,调用TCPSocket#readline。这是现在的功能:defreadThread.newdowhileline=@socket.readline#TODO:stuffendendend由于线程调度,如果这样写我的测试会失败:it"readsfromsocket"dosubject.socket.should_receive(:readline)subject.readend目前我知道解决这个问题的唯一方法是使用sleep0.1。有没有办法适本地延迟测试,直到该线程运行? 最佳

ruby - 将元数据添加到 PDF

我需要将元数据添加到我使用prawn创建的PDF中.该元数据稍后可能会被pdf-reader提取。.此元数据将包含内部文档编号和下游工具所需的其他信息。将元数据与PDF的每一页相关联会很方便。ThePDFspecification声称我可以将每页私有(private)数据存储在“Page-PieceDictionary”中。第14.5节指出:Apage-piecedictionary(PDF1.3)maybeusedtoholdprivateconformingproductdata.ThedatamaybeassociatedwithapageorformXObjectbymeans